package br.com.atenas.sigop.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import br.com.atenas.sigop.dto.FilmeDTO;

public class FilmeDAO {
	private String tabela = " SIGOP.TB003_FILME ";
	
	public void gravar(FilmeDTO filme, Connection conn) throws Exception{
		String sql = " INSERT INTO" + tabela +
		"(NU_MATERIAL, DE_TITULO, DE_ESTADO, DE_OBSERVACAO, QTD_FILME, NU_TPMATERIAL) VALUES (?,?,?,?,?,?)";
		PreparedStatement ps = conn.prepareStatement(sql);
		int index = 1;
		preecherPK(filme, conn);
		ps.setBigDecimal(index++, filme.getNuMaterial());
		ps.setString	(index++, filme.getTitulo());
		ps.setString	(index++, filme.getEstado());
		ps.setString	(index++, filme.getObservacao());
		ps.setBigDecimal(index++, filme.getQuantidade());
		ps.setBigDecimal(index++, filme.getNuTpMaterial());
		ps.executeUpdate();
	}
	
	private void preecherPK (FilmeDTO filme, Connection conn)throws Exception{
		String sql = "select SQ003_FILME.nextval from dual";
		PreparedStatement ps = conn.prepareStatement(sql);
		ResultSet rs = ps.executeQuery();
		rs.next();
		filme.setNuMaterial(rs.getBigDecimal(1));
	}
	
	public List<FilmeDTO> pesquisar(FilmeDTO filme, Connection conn) throws Exception{
		List<FilmeDTO> filmes = new ArrayList<FilmeDTO>();
		String sql = " SELECT NU_MATERIAL, DE_TITULO, DE_ESTADO, DE_OBSERVACAO, QTD_FILME" +
					 " from" + tabela +
					 " WHERE DE_TITULO like ?";
		PreparedStatement ps = conn.prepareStatement(sql);
		ps.setString(1, filme.getTitulo()+"%");
		ResultSet rs = ps.executeQuery();
		while(rs.next()){
			FilmeDTO filmeResultado = new FilmeDTO();
			filmeResultado.setNuMaterial(rs.getBigDecimal("NU_MATERIAL"));
			filmeResultado.setTitulo	(rs.getString("DE_TITULO"));
			filmeResultado.setEstado	(rs.getString("DE_ESTADO"));
			filmeResultado.setObservacao(rs.getString("DE_OBSERVACAO"));
			filmeResultado.setQuantidade(rs.getBigDecimal("QTD_FILME"));
			filmes.add(filmeResultado);
		}
		return filmes;
	}

	public void alterar(FilmeDTO filme, Connection conn) throws Exception{
		
		String sql = "UPDATE" + tabela + "SET DE_TITULO = ?, DE_ESTADO = ?," +
					 " DE_OBSERVACAO = ?, QTD_FILME = ? WHERE NU_MATERIAL = ?";  
		PreparedStatement ps = conn.prepareStatement(sql);
		int index = 1;
		ps.setString(index++, filme.getTitulo());
		ps.setString(index++, filme.getEstado());
		ps.setString(index++, filme.getObservacao());
		ps.setBigDecimal(index++, filme.getQuantidade());
		ps.setBigDecimal(index++, filme.getNuMaterial());
		ps.executeUpdate();
		ps.close();
	}

	public void excluir(FilmeDTO filme, Connection conn) throws Exception{
		
		String sql = "DELETE FROM" + tabela + "WHERE NU_MATERIAL = ?";
		PreparedStatement ps = conn.prepareStatement(sql);
		int index = 1;
		ps.setBigDecimal(index++, filme.getNuMaterial());
		ps.executeUpdate();
		ps.close();
	}
}